<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>排他思想(算法)</title>
</head>

<body>
    <button>按钮1</button>
    <button>按钮2</button>
    <button>按钮3</button>
    <button>按钮4</button>
    <button>按钮5</button>

    <script>
        // *如果有同一组元素,我们想要某一个元素实现某种样式,需要用到循环的排他思想算法
        // 1.所有元素全部清除样式
        // 2.给当前元素设置样式
        // 3.注意顺序不能颠倒 



        // 1.获取所有按钮元素
        var btns = document.getElementsByTagName('button');
        for (var i = 0; i < btns.length; i++) {
            // btns得到的是伪数组 里面的每一个元素 btn[i]
            btns[i].onmouseover = function() {
                // console.log('ojbk');
                // 核心思路
                // 1.可以先把所有的按钮背景颜色去掉 用for一次到位
                for (var i = 0; i < btns.length; i++) {
                    btns[i].style.backgroundColor = '';
                }
                // 2.然后才让点击的当前元素背景颜色变为 red
                this.style.backgroundColor = 'red';
            }
        }
    </script>
</body>

</html>